<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        .div {
            width: 300px;
            height: 300px;
            background-color: aqua;
        }

        .div1 {
            width: 200px;
            height: 200px;
            background-color: blanchedalmond;
            margin: 30px auto;
            text-align: center;
            line-height: 200px;
        }
    </style>
</head>

<body>
    <div class="div">
        ph
        <div class="div1">hg</div>
    </div>
    <!-- 事件发生时会在元素节点之间按照特定的顺序传播，传播过程即dom事件流 -->
    <script>
        // onclick和addEventListener 只能得到冒泡阶段
        // addEventListener('事件类型'，函数，usecapture)
        // 第三个参数 如果是true 表示在事件捕获阶段调用事件处理程序
        // 如果是false(不写默认false) 表示在事件冒泡阶段调用事件处理程序


        // 1 如果是true 就是捕获阶段 就是从外到里 body-->.div1-->.div

        // var div1 = document.querySelector('.div1')
        // div1.addEventListener('click', function () {
        //     alert('胡歌生孩子。')
        // }, true)

        // var div = document.querySelector('.div')
        // div.addEventListener('click', function () {
        //     alert('彭于晏该着急了。')
        // }, true)

        // var bo = document.body
        // bo.addEventListener('click', function () {
        //     alert('赵玉真也着急。')
        // }, true)


        // 2 如果是false 就是冒泡阶段 就是从外到里.div-->.div1--> body
        
        var div1 = document.querySelector('.div1')
        div1.addEventListener('click', function (e) {
            alert('胡歌生孩子。')
           e.stopPropagation();// 阻止冒泡
        }, false)

        var div = document.querySelector('.div')
        div.addEventListener('click', function () {
            alert('彭于晏该着急了。')
        }, false)

        var bo = document.body
        bo.addEventListener('click', function () {
            alert('赵玉真也着急。')
        }, false)


        // 实际开发中我们很少关注事件捕获，更关注事件冒泡
        //    有些事件是没有冒泡的 比如：onblur onfocus onmouseenter onmouseleave
    </script>
</body>

</html>